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(54) Energy-saving cache control system 

(57) A cache control system 108 for use with data storage apparatus having a movably mounted storage 
element such as a magnetic or optical disk 104, and solid-state cache memory 106, In which the storage 
element is not at operating speed when data access has not occurred during a predetermined time period, 
comprises means arranged to access data stored on the storage element tf a read or write request cannot be 
satisfied via access to the cache memory and a cache replacement mechanism for transferring data between 
the cache memory and the storage element to maintain consistency of data therebetween. The system is 
characterised in that the cache replacement mechanism performs data transfers between the cache memory 
and the storage element only while the storage element is at operating speed after such a read or write 
request has given rise to an access to the storage element Power consumption is thus reduced. 
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CACHE CONTROL SYSTEM 

The invention relates to a cache control system for use in data 
storage apparatus in a computer and, more particularly, to a cache 
control system which reduces power consumption in such data storage 
5 apparatus having a movably mounted storage element, such as a magnetic or 
optical disk or the like. 

The popularity of portable battery-operated computers has made the 
need to reduce the power consumption of computer systems very important. 
This is because the capacity of batteries is limited and it is desirable 
10 to maKimise the amount of time for which the portable computer can be 
used without having to replace the batteries or to connect the computer 
to a mains electricity supply in order to recharge the batteries. 

In addition, increased attention to environmental and ecological 
considerations has given rise to the requirement to design desktop 
15 personal computers with reduced energy consumption. 

Since it usually has moving parts, such as a magnetic or optical 
disk, the data storage sub-system of such computers is very often a major 
contributor to the power consumption of the device as a whole. 

This invention is directed to the problem of reducing the power 
20 consumption of data storage apparatus having a movably mounted element, 
such as a disk. The invention finds particular application with, but is 
not limited to, disk storage subsystems for personal and portable 
computers. 

A number of computer data storage systems have been proposed which 
25 make use of solid state memory devices as a front end to rotating 

magnetic disk devices. These systems use a high speed solid state memory 
unit as a holding area for data stored on relatively lower speed magnetic 
disk storage, thereby increasing the speed of access as compared to the 
use solely of relatively lower speed disk storage. Such a system is 
30 disclosed, for example, in WO 92/15933. 

From a first aspect, this invention provides a cache control system 
for use with data storage apparatus having a movably mounted storage 
element and solid-state cache memory, in which data storage apparatus the 
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storage element is not at operating speed V7hen data access has not 
occurred during a predetermined time period, the cache control system 
being responsive to read and write requests from a computer and 
comprising means arranged to access data stored on the storage element if 
5 a read or write request cannot be satisfied via access to the cache 
memory and a cache replacement mechanism for transferring data between 
the cache memory and the storage element to maintain consistency of data 
therebetween, characterised in that the cache replacement mechanism is 
arranged, in operation, to perform data transfers between the cache 
10 memory and the storage element only while the storage element is at 

operating speed after a read or v/rite request has given rise to an access 
to the storage element. 

Power consumption is reduced because disk accesses which are caused 
by the need to maintain consistency between the data stored in the cache 
15 and on the storage element are restricted to occasions when an access to 
the storage element would be required anyway because a read or write 
request could not be satisfied from the cache. Since the number of times 
the storage element has to be accelerated to operating speed is reduced, 
the power consumption is also reduced, 

20 Thus in one embodiment such a control system takes advantage of the 

fact that disks of portable workstations are usually turned off if no 
activity against them takes place during a certain period of time. When 
the disk is idle, and a Read/Write request is issued, energy has to be 
spent on accelerating the disk to its operational speed. 

25 The cache is used as a repository enabling small separate 

Read/Write operations to be performed without activating the disk. 

In the apparatus of the present invention, unlike with a 
conventional cache memory, the cache memory device does not necessarily 
have to be faster than the data storage. Rather it is sufficient if it 
30 is accessible with a lower power consumption - 

Unlike a conventional cache control system, a system arranged in 
accordance with the present invention is not designed to overlap 
operations. Rather it is designed to effectively batch operations. The 
prior art cache replacement algorithms tend to use independent 
35 activations of the disk by the cache replacement mechanism in the 



background to ensure that the probability that a read or write request 
can be satisfied via access to the cache alone is maximised. Since the 
energy penalty for activating the disk is high, the cache replacement 
algorithm of this invention is intended to minimize the number of 
required disk activations rather than minimise the required number of 
disk accesses as in the prior art. 

Suitably, the cache replacement mechanism can be arranged to carry 
out transfers from the cache memory to the storage element for a 
predetermined time each time a read or write request has given rise to an 
access to the storage element - 

Thus, it is possible that large chains of accesses to the disk to 
sequences of segments which are not necessarily sequential will be made 
because the energy saved by making these accesses after a required disk 
access amortizes the spin-up energy of the disk. 

Preferably, the cache control system comprises means operable to 
access the data on the storage element without modifying the data in the 
cache memory if the read or write request involves more than a 
predetermined amount of data. This is more efficient since it avoids 
access to the cache where it is clear that it will not be possible to 
satisfy read or write requests from the cache. 

In an advantageous form of the invention the cache control system 
comprises means to identify a set of sectors associated with each sector 
and wherein the cache replacement mechanism is operable to transfer all 
members of the associated set of sectors from the storage element to the 
cache memory when a read or write request has given rise to the sector 
being read from the storage element. 

Thus, by appropriate maintenance of the sets of associated sectors, 
use can be made of spatial locality of access to maintain in cache the 
sectors that are most likely to be accessed at any given time. 

Conveniently, the associated sets of sectors can be efficiently 
maintained by identifying, at any particular time, the sectors that have 
been accessed in a preceding predetermined time interval and by updating 
the set of sectors associated with a sector, when a read or write request 
has given rise to the sector being read from the storage element, by 
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adding to the set the sectors that have been accessed in the preceding 
predetermined time interval. 

Preferably, the updating mechanism is also arranged to determine 
whether each sector in the associated set has been accessed in the 
5 preceding predetermined time period and to remove the sector from the set 
after determining on a predetermined number of occasions that the sector 
has not been accessed in the preceding predetermined time period. 

In one embodiment the system comprises, for at least a subset of 
the sectors, means to determine and store an indication whether each 

10 sector was accessed on the most recent occasions when it was brought into 
the cache and the cache replacement mechanism is arranged to transfer a 
sector from the storage element to the cache memory when a read or write 
request has given rise to the sector being read from the storage element 
only if the sector was accessed on the most recent occasions when it was 

15 brought into the cache. 

This allows the system to identify sectors which, once brought into 
the cache are not referenced again. If this pattern is repetitively 
observed these sectors are not brought to the cache to allow better 
utilisation of the cache space. 

20 The invention also provides data storage apparatus comprising such 

a cache control system, an optical or magnetic disk drive and a non- 
volatile solid state cache memory. Advantageously, the data storage 
apparatus is in the form of a disk storage subsystem for use with a 
personal or portable computer. In this form, the data storage apparatus 

25 can be designed to preserve the external interface of the disk subsystem 
and require no special support at the system level whatsoever, thus 
enabling the subsystem to directly replace a conventional hard disk 
drive . 

Viewed from another aspect, the invention provides a method for 
30 operating data storage apparatus having a movably mounted storage element 
and solid-state cache memory, in which data storage apparatus the storage 
element is not at operating speed when data access has not occurred 
during a predetermined time period, the method comprising accessing data 
on the storage element in response to a read or write request which 
35 cannot be satisfied via access to the cache memory, and transferring data 
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between the cache memory and the storage element to maintain consistency 
of data therebetween, characterised in that data transfers between the 
cache memory and the storage element are performed only while the storage 
element is at operating speed after a read or write request has given 
5 rise to an access to the storage element. 

An embodiment of the invention will now be described, by way of 
example only, with reference to the accompanying drawings, wherein: 

Fig. 1 is a schematic diagram showing data storage apparatus; 

Figs 2a and b illustrate data structures stored in the cache control 
10 mechanism; 

Fig 3 is a flow diagram showing steps performed when a sector is 
transferred from disk to cache; 

Fig 4 is a flow diagram showing the operation of data storage apparatus 
during a read operation; 

15 Fig 5 is a flow diagram showing the operation of data storage apparatus 
during a write operation; 

Fig 6 shows a graph of the power consumption against time of data storage 
apparatus in operation. 

Referring to Figure 1 a data processing system comprises a computer 
20 100 which is attached to a data storage apparatus 110 via a SCSI (Small 
Computer Systems Interface) 101. The operation of a such an interface 
and =the hardware and software required to implement it will be well 
understood by those skilled in the art and will not be described further 
here. It suffices for the purpose of the present description that the 
25 data storage apparatus be responsive to read and v/rite requests passed 
from the computer via the interface to fetch and store data. 

■ Data storage apparatus 110 comprises: magnetic disk storage device 
104 which has, in this example, a capacity of 120 Megabytes; cache system 
102 which includes non-volatile solid-state cache memory 106 having a 
30 capacity, in this example, of 2 Megabytes and cache control or management 
logic 108. The cache control system 108 includes a suitable 
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microprocessor together with associated control code to enable it to 
perform the various functions described lie rein and cache management 
tables for storing control data for the cache memory and data storage 
devices. 

5 The magnetic disk storage device 104 is of a type well known in the 

art and comprises a rotatably mounted magnetic disk together with a drive 
motor, a read/write head assembly and an associated control system. 

It will be understood that whilst the example of a magnetic disk 
storage device is used for the puiposes of this discussion, the invention 
10 would be equally applicable to any data storage device having a movable 
component such as an optical disk drive or the like. 

In this embodiment, the data storage apparatus is in the form of an 
integrated disk storage subsystem so that it appears to the computer 100 
as a single addressable entity with data transfers between the cache 
15 memory and the data storage device being performed over private data 
transfer lines within the apparatus. Hov;ever, with suitably arranged 
data buses, the functions of the cache control system could equally be 
performed by the computer itself. 

The disk storage device 104 has 3 possible states: standby, idle 
20 and active. In the active state the disk is rotating at operating speed 
and Read/Write and Seek operations are performed- The typical power 
required in this state can be between 1.5W and 2.5W. In the idle state 
the disk is still at operating speed and the typical power consumption is 
0.9W. There is no power overhead when going from the idle state to the 
25 active state. The standby state in which the disk is stationary has the 
lowest power consumption - typically 0.2V?. Switching from the standby 
state to the active state necessitates the disk to be brought to 
operating speed- This spin-up typically requires a power of up to 4W 
over the acceleration time. The acceleration time is relatively long 
30 compared to an I/O operation. 

An example of a commercially available disk drive of this type is 
the Maxtor 2.5 inch disk drive model number 25252A- Its power ratings 
are as follows: spin-up power is 2.8W and the drive takes 2s to reach 
operating speed; active power is 1.6W; idle is 0-9W; standby is O.IW. 
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The data in the storage apparatus is arranged in sectors, which are 
the smallest addressable unit of data on the disk. Each sector contains, 
for example, 512 bytes of data. 

The cache memory 106 contains data corresponding to n sectors 
5 S],.,,, Sn of the disk. Each in-cache sector can be in one of three 
states: 

(i) Invalid. A sector which is designated Invalid does not contain 
meaningful data. 

(ii) Consistent. A sector which is designated Consistent contains the 
10 same information as that stored on the corresponding disk sector. 

(iii) New. A sector which is designated New contains information fresher 
than that stored on the corresponding sector on the disk. 

The cache control system collects statistics relating to access 
patterns to sectors on the disk in a cache management table and tries to 
15 guess, using these statistics, the behavioral patterns of the sectors in 
the given system. 

Figure 2a is a schematic diagram showing the cache management table 
200 of the cache control system. For each sector of the disk Sj, there 
is an entry 210 in the table. 

20 Each entry contains information conventionally stored for sectors 

of a cache memory, such as an indication that the sector is in-cache and 
its status if it is (New, Consistent, or Invalid), time stamps and the 
like. This conventional information is not shown in Fig 2a, 

In addition, each entry contains the following information 
25 illustrated schematically in fig 2b. 

Each entry contains the following data 220 relating to the data 
access history of the sector r 

(1) a historical indication 222 which indicates the status of the recent 
access history of the sector; and 
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(2) three reference counts 224 which indicate the number of times the 
sector was accessed on the last three occasions it was brought into the 
cache . 

The purpose of the historical reference indication is to identify 
5 sectors that once brought into the cache are not referenced again. If 
this pattern is repetitively observed these sectors need to be passed 
directly to the system in subsequent invocations to allow better 
utilization of the cache space. 

The historical reference indication 222 is a variable that is 
10 initially set to a value of -1 that indicates that a proper value has not 
yet been set. When the sector is accessed for the first time the 
historical indication is set to another value, eg 1 to indicate that the 
sector has been accessed. If the three reference counts are all zero, 
the historical indication is set to a third value, eg 0, to indicate that 
15 the sector was not accessed on the recent occasions when it was brought 
into the cache. 

Also stored in the table entry is affinity information 226. The 
affinity information 226 describes which sectors are usually loaded 
during the same time interval. 

20 In addition to the information stored in the cache management table 

200, certain global information is also stored by the cache management 
system. This global information includes various system parameters and 
tunable parameters and a table of the sector IDs of the sectors for which 
read requests have most recently been received during a certain time 

25 window as will be explained below. These sectors will be referred to as 
the current generation window. 

In the following, the term ' genera tion* will be used to refer to a 
sufficiently short time interval during v/hich all sector reads issued are 
suspected to come from the same or related applications. This time 
30 period is a tunable parameter that is used by the cache control unit for 
managing the cache. 

A group of sectors will be referred to as * contemporaries ' if they 
are brought into memory within this same generation. A contemporary group 
might have one or more members. If a sector that belongs to a 
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contemporary group is accessed there is a high likelihood that other 
members of the group will also be accessed. 

In cache management table 200, the affinity information comprises a 
bit map 228, having a bit for every sector of the disk. The bit map is 
5 used as a set data structure which records the contemporary group for the 
sector. It will be appreciated that other structures are possible for 
this information. For example, another possible implementation could use 
a tree structure. 

The data in the cache management table is continuously updated and 
10 refined to allow the system to "learn" the patterns of usage in order to 
maximize the energy saving. 

The affinity between sectors is calculated using the generation 
parameter. Sectors that are believed to be brought in by the same 
application or related applications as any one particular sector are 
15 marked in the bit map as contemporaries of the sector and brought into 
the cache together with it each time the sector is brought into the 
cache . 

The contemporary information is dynamically updated to reflect 
factors such as coincidence rather than logical affinity in the original 
20 affiliation decision, changes in the usage pattern or reallocation of the 
sector to a new file. 

The algorithm for updating the contemporary groups takes into 
account the facts that any update algorithm is an approximation used to 
predict the access pattern of the disk and that to err by bringing an 
25 unneeded sector into the cache consumes less energy than to err by 
missing a needed sector. 

The aim of this algorithm is to keep in the same contemporary group 
sectors which have been frequently -and recently accessed together within 
a short time interval. 

30 The identity of the sectors for which read requests have been 

issued within a time window of a generation is maintained by the cache 
control system as explained above. This information is used in order to 
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update the contemporary group of a sector each time it is brought into 
the cache from the disk. 

For each sector in the contemporary group two integers are 
maintained in the cache management table: Mode 232 and LU (Last Updated) 
5 230. 

Each time that a sector is transferred from the disk to the cache 
the process illustrated in Fig 3 is performed. The contemporary group of 
the sector is compared with the identity of the sectors in the current 
generation window. The Mode value of sectors in the intersection of the 

10 sets is incremented by one and their LU value is set to 1 , Sectors that 
are in the current generation window but not in the contemporary group 
are added into the contemporary group of the sector being transferred 
with Mode value of 1 and LU value of 1. Sectors that are in the 
contemporary group and not in the current generation window are deleted 

15 from the contemporary group of the sector being transferred if their LU 
value is greater than a predetermined value k. Otherwise their LU value 
is incremented by one and their Mode is left unaltered. The Mode value 
is used when moving data to the cache since contemporary segments are 
read in nonincreasing order of Mode. 

20 The whole contemporary set is transferred from the disk only if 

enough space is available in the cache. When writing to the cache all 
Invalid or Consistent sectors may be replaced, but it is not possible to 
replace New sectors. When there are not enough invalid or consistent 
sectors in the cache, the mode value comes into play and only as many 

25 sectors as space permits are read into the cache. Conveniently, the size 
of the cache is selected so that most of the time the whole contemporary 
group can fit in the cache. 

Ideally the cache management table should store information 

relating to all sectors on the disk. When storage space is' insufficient, 

30 information on the more frequently used sectors can be kept in a 

hash-table structure as will be well understood by those skilled in the 
art. 

The cache control system has a cache replacement mechanism which 
performs two main tasks: destaging ie transferring data from the cache to 
35 disk, and replacement. 
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The cache control system executes destage operations only when the 
disk is spinning anyway. Only New sectors are destaged. Each sector 
which has been destaged is marked Consistent. 

The term 'idle stretch* (IS) of a sector will be used to refer to 
5 the current time minus the most recent time that any sector in its 

contemporary group was used. Thus each sector in a contemporary group 
has the same idle stretch. The idle stretch for each sector is stored in 
the entry for the sector in the cache management table 200 as shown in 
Figs 2a and 2b. 

10 Destaging is performed by arranging the sectors Sj , . . . , in the 

'New* state in the cache in nonincreasing order of their IS value and in 
an ascending order according to the sector ID within the same IS value. 
This ordering avoids destaging sector groups which might soon be 
re-accessed. Ordering using the sector ID as a secondary key minimizes 

15 the destaging seek time. The order in v;hich Sectors are destaged will be 
referred to as the Destaging Order - 

Each time a read or write request has .given rise to an access to 
the disk storage device, a destage takes place for a certain period of 
time if there are New sectors in the cache. The maximum period of time 
20 for which destaging takes place on each occasion is determined by 

allocating a certain energy budget to it. For example, if keeping the 
disk in active state for t time units takes about the same energy as is 
required to spin up the disk, then, destaging will occur during at + b 
units of time, where a and b are system- dependent tunable parameters. 

25 The parameters a and b should be adjusted so that this time 

interval is sufficiently long to amortize the energy required to bring 
the disk to operating speed. This period will be referred to as the 
destaging interval. 

The destage operation, ie the transferring of data from the cache 
30 106 to the data storage device 104 transforms New sectors in the cache 
into Consistent sectors. This is one part of the cache replacement 
mechanism. 

The cache replacement mechanism obeys the following rules for 
replacing sectors in the cache. A New sector is replaced only as a 
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result of a Write operation which provides a fresher version of that 
sector. It then remains New. A Mew or Consistent sector becomes Invalid 
if a Write operation is performed directly to the data storage device 104 
bypassing the cache. 

5 A Consistent or Invalid sector may be replaced either (i) as a 

result of a Write operation of a new sector or a fresher version of the 
same sector in which case it then becomes New or (ii) as a result of a 
Read operation which brings a sector into the cache from the disk. It 
then remains; or becomes Consistent. 

10 The methods used by the cache control system to handle read and 

write requests from the computer 100 are shown in Figs 4 and 5 
respectively. A distinction is made betv^een different I/O request 
patterns as described in the follovjing. 

15 As shovm in Fig 4, any read request is examined to see if the 

request is for more than a predetermined number of sectors • This 
threshold will be dependent on the size of the cache and the 
characteristics of the disk. Such large requests are satisfied by 
transferring the data directly from the disk to the main memory of the 

20 computer 100. Since the disk is in the Read/Write state and the disk 
must be accelerated to its operating speed, any required destaging is 
also performed for a period of time equal to the destaging interval- 

The threshold will be determined by the cache size- Large I/O 
25 requests will not fit into the cache and will inevitably require disk 

activations. There is thus no point is satisfying these from the cache. 

If the read request is for a number of sectors less than the 
threshold, then the request is satisfied from the cache. If a cache miss 
occurs, the disk will be activated, the read request for that sector will 
30 be satisfied from the disk and missing sectors as well as related sectors 
may be read into the cache. In the event of a cache miss, a destage is 
performed if necessary as before since the disk is already active. 

As shown in Fig 5, a write operation follows the same philosophy. 
If the write request is for a large number of sectors, then they are 
35 written directly to the disk. If necessary, a destage is performed at 
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this opportunity. If the write is not large then the sector is written 
to the cache. 

Thus, when reading data three subcases may arise. If the cache 
contains all the requested information, then the request is served from 
cache. If the cache does not contain all the requested information and 
the amount of data to be read is above the threshold, ie is large, then 
the data flowing from the disk to the system will not be stored in the 
cache. In other words, in this case, the cache content is not changed. 

If the cache does not contain all the requested information and the 
amount of data to be read is below the threshold, ie is small, and there 
are enough Invalid or Consistent sectors in the cache, then the data 
unavailable in the cache will be read from the disk. 

When any particular sector is accessed on the disk following a 
cache miss resulting from a read request, its historical reference 
indication 222 is used to determine whether or not it is transferred to 
the cache by distinguishing between the three possible cases. 

If the historical reference indication indicates that it has been 
recently accessed, then the sector and its contemporaries are read into 
the cache. The latest reference count of the sector is set to 1. The 
latest reference count of its contemporaries is set to 0, 

In the case where the historical reference indication is not set, 
the sector is moved both to the cache and the system; its latest 
reference count is set to 1. In this case, the set of contemporaries 
comprise of only that sector, since the set of contemporaries is 
initially an empty set. 

If the historical reference indication shows that the sector has 
not been recently accessed, then only its contemporaries are read into 
the cache. Sector s itself is passed to the system, but not read into 
the cache. The latest reference count of the sectors in the contemporary 
group is set to 0. 

When writing data only two subcases may arise. When writing a 
small amount of data, each sector which exists in the cache is replaced 
by the newer version, and is marked New. Sectors not already in the 
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cache are written into the cache, by replacing other existing consistent 
sectors, if there is a sufficient number of these. 

When writing an amount of data more than the threshold to the disk, 
the cache sectors which contain data on V7hich the system is writing, are 
5 marked Invalid, but the actual Write operation goes directly to the disk- 
Figure 6 is a schematic diagram illustrating the use of a system 
with such apparatus. An application program 600 running on the computer 
gives rise to read and write requests to disks which are passed under the 
control of operating system 610 to the disk storage subsystem 620. 

10 When the user starts the system, all the applications are loaded 

and relevant sectors are loaded into the cache. Once this initial phase 
630 is over, the disk goes to its lowest energy state and stays there 
until either a read miss, a large read or a large write occurs, in which 
event the energy consumption increases as shown at 640. In practice, the 

15 disk will be in the standby position most of the time. 

This particular design of the data storage apparatus preserves the 
external interface of the disk, and needs no special support at the 
system level whatsoever. 

The effectiveness of the cache is due to the fact that the memory 
20 which the cache is made of consumes less power than the disk when it is 
in idle state. Disk activations arid duration of activations are budgeted 
to conserve energy. 

The principle of locality of access means that it is possible to 
maintain in the cache a subset of all the sectors, and ensure that access 
25 to the disk is relatively rare. It is the principle of locality that 
allows the right sectors to be effectively maintained in the cache. 

There are three types of locality, macro spatial, micro spatial 
and temporal. The first two relate to the reference pattern 
the third relates to time. An application is said to have a good micro 
30 spatial locality if, within the same execution, the probability of 

accessing data located near the currently accessed data is higher than 
accessing other data. An application is said to have a good macro 
spatial locality if the set of sectors accessed by a program does not 
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vary from execution to execution. An appliccition is said to have a good 
temporal locality if there is a high likelihood of accessing data which 
was recently accessed. 

The tunable parameter generation together with the destaging order 
5 allow us to follow the principle of locality and maintain the sectors 

that are most likely to be accessed in the cache for small read and write 
requests . 

The historical indication maintained v/ith every sector allows 
advantage to be taken of temporal locality. The use of groups of 
10 contemporary sectors together with the historical reference indication 
allows us to retain the sectors with good spatial locality in cache. 

Advantage is taken of the fact that most applications work with 
very small files. The typical size of a file in the UNIX operating 
system, for example, is smaller than 4KB (UNIX is a trademark of Unix 
15 System Laboratories Inc). 

Thus, like the traditional cache memory it is designed on the basis 
of the principle of locality, but that is the only similarity. Unlike 
traditional cache, the memory it is made of is not necessarily faster, 
but only has to consume less power. 
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CLAIMS 

1. Cache control system (108) for use with data storage apparatus 
(110) having a movably mounted storage element (104) and solid-state 
cache memory (106), in which data storage apparatus the storage element 

5 is not at operating speed when data access has not occurred during a 
predetermined time period, the cache control system (108) being 
responsive to read and write requests from a computer (100) and 
comprising means arranged to access data stored on the storage element 
(104) if a read or write request cannot be satisfied via access to the 

10 cache memory (106) and a cache replacement mechanism for transferring 
data between the cache memory (106) and the storage element (104) to 
maintain consistency of data therebetween, characterised in that the 
cache replacement mechanism is arranged, in operation, to perform data 
transfers between the cache memory (106) and the storage element (104) 

15 only while the storage element is at operating speed after a read or 
write request has given rise to an access to the storage element (104)- 

2. Cache control system as claimed in claim 1 or claim 2 wherein the 
cache replacement mechanism is arranged to carry out transfers from the 
cache memory to the storage element for a predetermined time each time a 

20 read or write request has given rise to an access to the storage element 
(104) . 

3* Cache control system as claimed in claim 1 or claim 2 comprising 
means arranged to access the data on the storage element without 
modifying the data in the cache memory if the read or write request 
25 involves more than a predetermined amount of data, 

4. Cache control system as claimed in any preceding claim for use with 
data storage apparatus in which data is arranged in sectors and 
comprising, for at least a subset of the sectors, means (228) to identify 
a set of sectors associated with each sector and wherein the cache 

30 replacement mechanism is operable to transfer all members of the 

associated set of sectors from the storage element (104) to the cache 
memory (106) when a read or write request has given rise to the sector 
being read from the storage element (104). 

5. Cache control system as claimed in claim 4 comprising means 

35 responsive to a read or write request having given rise to an access to 
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the storage element (104) to transfer to the storage element sectors in 
the cache which contain information fresher than that stored on the 
corresponding sectors in the storage element in non-increasing order of 
the current time minus the most recent time that any sector in the group 
5 of sectors associated with the sector was accessed, 

6. Cache control system as claimed in claim 3 or claim 4 comprising 
means to identify, at any particular time, the sectors that have been 
accessed in a preceding predetermined time interval and a mechanism 
arranged to update the set of sectors associated with a sector, when a 

10 read or write request has given rise to the sector being read from the 
storage element (104), by adding to the set the sectors that have been 
accessed in the preceding predetermined time interval. 

7. Cache control system as claimed in claim 6 wherein the updating 
mechanism is arranged to determine whether each sector in the associated 

15 set of sectors has been accessed in the preceding predetermined time 
period and to remove the sector from the set after determining on a 
predetermined number of occasions that the sector has not been accessed 
in the preceding predetermined time period- 

8. Cache control system as claimed in any of claims 4 to 7 comprising, 
20 for at least a subset of the sectors, means to determine and store an 

indication whether each sector was accessed on the most recent one or 
more occasions when it was brought into the cache and wherein the cache 
replacement mechanism is arranged to transfer a sector from the storage 
element to the cache memory when a read or write request has given rise 
25 to the sector being read from the storage element (104) only if the 

sector was accessed on the most recent one or more occasions when it was 
brought into the cache - 

9. Data storage apparatus comprising a cache control system as claimed 
in any preceding claim, an optical or magnetic disk drive and a non- 
30 volatile solid state cache memory. 

10. Data storage apparatus as claimed in claeim 9 in the form of a disk 
storage subsystem for use with a personal or portable computer. 

11. Method for operating data storage apparatus (110) having a movably 
mounted storage element (104) and solid-state cache memory (106), in 
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which data storage apparatus the storage element is not at operating 
speed when data access has not occurred during a predetei-mined time 
period, the method comprising accessing data on the storage element in 
response to a read or write request which cannot be satisfied via access 
5 to the cache memory (106), and transferring data between the cache memory 
(106) and the storage element (104) to maintain consistency of data 
therebetween, characterised in that data transfers between the cache 
memory (106) and the storage element (104) are performed only while the 
storage element is at operating speed after a read or write request has 
10 given rise to an access to the storage element (104). 
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